package cn.iocoder.yudao.module.ao.controller.admin.curriculum.vo;

import io.swagger.v3.oas.annotations.media.Schema;
import lombok.*;
import java.util.*;
import java.math.BigDecimal;
import org.springframework.format.annotation.DateTimeFormat;
import java.time.LocalDateTime;
import com.alibaba.excel.annotation.*;

@Schema(description = "管理后台 - 课程体系 Response VO")
@Data
@ExcelIgnoreUnannotated
public class CurriculumRespVO {

    @Schema(description = "课程体系ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "28945")
    @ExcelProperty("课程体系ID")
    private Long curriculumId;

    @Schema(description = "所属专业ID", requiredMode = Schema.RequiredMode.REQUIRED, example = "25131")
    @ExcelProperty("所属专业ID")
    private Long majorId;

    @Schema(description = "课程体系名称", requiredMode = Schema.RequiredMode.REQUIRED, example = "芋艿")
    @ExcelProperty("课程体系名称")
    private String curriculumName;

    @Schema(description = "课程体系编码", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("课程体系编码")
    private String curriculumCode;

    @Schema(description = "版本号", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("版本号")
    private String version;

    @Schema(description = "生效年份", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("生效年份")
    private String effectiveYear;

    @Schema(description = "总学分")
    @ExcelProperty("总学分")
    private BigDecimal totalCredits;

    @Schema(description = "必修学分")
    @ExcelProperty("必修学分")
    private BigDecimal requiredCredits;

    @Schema(description = "选修学分")
    @ExcelProperty("选修学分")
    private BigDecimal electiveCredits;

    @Schema(description = "实践学分")
    @ExcelProperty("实践学分")
    private BigDecimal practicalCredits;

    @Schema(description = "课程体系描述", example = "你猜")
    @ExcelProperty("课程体系描述")
    private String description;

    @Schema(description = "状态（0正常 1停用）", requiredMode = Schema.RequiredMode.REQUIRED, example = "1")
    @ExcelProperty("状态（0正常 1停用）")
    private Integer status;

    @Schema(description = "创建时间", requiredMode = Schema.RequiredMode.REQUIRED)
    @ExcelProperty("创建时间")
    private LocalDateTime createTime;

}